package com.cloud.code.牛客网;

import java.util.Arrays;

/**
 * 求出一个数组里面 ，每个元素比他小的个数
 */
public class Test4 {

    public static void main(String[] args) {
        int[] arr = {8, 1, 2, 2, 3};
        int[] sort = sort(arr);
        System.out.println(Arrays.toString(sort
        ));
    }

    public static int[] sort(int[] arr) {
        int sum[] = new int[10];
        int length = arr.length;
        for (int i = 0; i < length; i++) {
            sum[arr[i]]++;
        }

        //这里计算出每个数比他小的值。
        for (int j = 1; j < 10; j++) {
            sum[j] = sum[j] + sum[j - 1];
        }
        int[] ret = new int[length];
        for (int i = 0; i < length; i++) {
            ret[i] = sum[arr[i] - 1];
        }
        return ret;
    }
}
